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A cost effective deinterlcaving apparatus is selectively configurable for data streams interleaved accoiding to one of a plurality of 
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RECONFIGURABLE INTERLEAVER/DEINTERLEAVER AND ADDRESS GENERATOR FOR 
DATA STREAMS INTERLEAVED ACCORDING TO ONE OF A PLURALITY OF 
INTERLEAVING SCHEMES 



5 FIELD OF THE INVENTION 

The invention relates to the field of data processing and can be used to aid 
conununication systems which require noise tolerance. 

BACKGROUND OF THE INVENTION 

Communication systems use interleavers to transform data which has been 

10 corrupted by correlated noise into data in which the noise appears to be distributed 

in time with less correlation. The deinterleaver transforms the data back into its 
original form. The overall interleave/deinterleave operation is such that the 
received data is identical to the transmitted data in the absence of noise. Several 
algorithms have been developed which perform the interleave/deinterleave function. 

15 These algorithms lend themselves to different implementations, each with their own 
advantages and disadvantages. 

Two well known algorithms for interleaving and deinterleaving data were 
developed by John Ramsey and David Forney. John Ramsey's original work 
contains four different interleavers called type I, type II, type III, and type IV, 

20 Figure 1 illustrates Ramsey's origmal implementation of his type II ' 

interleaver. There are two parameters for the interleave, n2 and nl. The n2 
parameter specifies how many contiguous symbols in the interleaved sequence over 
which the minimum spacing nl is valid. The nl parameter specifies the mimmum 
spacing in the original stream that can be contamed in any n2 contiguous symbols 

25 in the interleaved stream. In Fig. 1 the blocks 101, 102, 103, and 104 are shift 

registers vrith delay n2-L The blocks 106, 107, 108, and 109 are adders which 
serve as muxes when nl and n2 are constrained appropriately. The constraints on 
n2 and nl are that n2 and nl+1 must be relatively prime and n2 > nl+l. The 
commutator switch 105 sequences counter-clockwise for every symbol received at 
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the input 111. The continuation symbol 1 10 indicates that the number of shift and 
add stages is not explicitly specified by the drawing. For this implementation, a 
total of nl*(n2-l) delay elements are required. The output is from 112. 

Figtire 2 illustrates a basic Forney r>*pe interleaver. The shift registers 200, 
5 201,202, and 203 are of length specified inside the register and shift the data one 

position to the right every input data symbol. For example, the shift register 
200 has a total delay of T*I and the shift register 201 has a total delay of 2*T*I. 
There are a total of I sets of shift registers. The commutators 204 and 205 move 
one position every input symbol and are synchronized with each other. In this 

10 docimient the value T*I is defined as N. There are a total of I*(M)*T/2 delay 

elements for the interleaver. A fomey interleaver is equivalent to ta Ramsey type 
III (not shown here) when N = nl + 1 and I = n2 and T is an integer. 

In the state of the art, there are two basic approaches to implementing the 
algorithms invented by Fomey and Ramsey. One approach is with the use of shift 

15 registers and this was the technique presented in the inventor's original works. 
This technique has the advantage of requiring the smallest number of memory 
elements. Another approach is with the use of a random access memory (RAM). 
This technique has the advantage of using a cheaper technology. A diagram 
contrasting these approaches is shown in Figure 3. In Fig. 3a, the data arrives as 

20 306 and exits either interleaved or deinterieaved as 307. The shift register is 304 
and the commutators 308 and 309. The control is shown as 305. In Fig. 3b, the 
RAM is 300. Data is written into the RAM in 302 and is read from the RAM is 
303. The 301 is the address generation and control for the operation. 

An apparatus implementing a single deinterleaving algorithm (such as those 

25 designed to deinterleave streams interleaved according to the techniques described 
above) suffers firom the drawback of only bemg able to deinterleave data streams 
interleaved by a single protocol. This proves particularly troublesome when users 
wish to design a system that can receive and deinterleave data interleaved using 
different interleaving algorithms. In the United States, the standard interleaving 

30 protocol for Direct Broadcast Satellite (DBS) systems is based on Ramsey's type II 
algorithm. In Europe, the protocol for DBS systems is based on Forney's 
algorithm. The result is that users must use a different deinterleaving apparatus 
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than when they deinterleave DBS data streams initiated in the United States as 
opposed to data streams from Europe. Similarly, manufacturers of deinterleaving 
equipment must build different devices for sale in the United States and Europe. 
W^at is needed is an apparatus that can be reconfigured to dejnter leave 
5 streams interleaved according to a plurality of interleaving schemes. 

SUMMARY OF THE INVENTION 

The present invention provides a cost effective deinterleaving apparatus that 
is selectively configurable for data streams interleaved according to one of a 
plurality of data streams (note that since a deinterleaver is also an interleaver this 
10 invention also is a configurable interleaving apparatus). This is accomplished v^th 

the invention of a single, cost efficient address generation unit that can be used for 
multiple algorithms by dynamically controlling key parameters during operation. 
The system level diagram of the deinterleaver is similar to that shown in Fig. 3b 
and Fig. 4, The key distinction is that the address generation and control imit is 
15 capable of deinterleaving a plurality of interleaved data streams with a cost efficient 
technique. It should be noted that there are no special constraints placed on the 
RAM by this invention. It can be any standard type, such as dynamic or static, 
single port or multiple port. 

According to the preferred embodiment of the present invention a Generate 
20 Write Address block remains the same for all interleaving protocols. It generates 

an address for writes which restarts every time the last address is written. A 
Generate Read Address block also remains the same for all interleaving protocols. 
It generates the read address for a RAM. The parameters specific to each 
interleaving algorithm are generated in a Parameter Set block. There can be an 
25 arbitrary number of Parameter Set blocks, one for each interleaving protocol. A 
switch selects the correct set of parameters for each interleaving protocol. Such a 
device allows the deinterleaving apparatus to receive a data stream which has been 
interleaved according to one of a plurality of interleaving schemes and output the 
original data stream. A control block is the same for all interleaved data streams 
30 and allows the address generation and parameter units to update based on data 

either being written to or read from the RAM. The Generate Write Address, 
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Generate Read Address and control blocks are used for all interleaving protocols, 
thereby providing cost efficiency. Additionally, in the preferred embodiment, the 
most complexity in these three blocks. This allows the Parameter Set blocks to be 
produced at verj^ low cost. 

5 BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 illustrates a Ramsey type II interleaver as described by John L. 
Ramsey. 

Figure 2 illustrates a Forney interleaver similar to description of David G. 

Forney. 

10 Figure 3 illustrates two different implementations of 

interleaver/deinterleavers in the state of the art. 

Figure 4 illustrates a block diagram of one embodiment of a circuit which 
performs deinterleaving according to a pluralit}^ of protocols. 

Figm-e 5 illustrates the a block diagram of the preferred embodiment of the 
1 5 present invention.^ 

Figure 6 illustrates one example of a hardware implementation of the 
address generation unit for deinterleaving a Ramsey type II or Forney interleaved 
data stream. 



DETAILED DESCRIPTION OF THE PRRFERRED EMBODTK/fFNT 

The present invention is for a deinterleaving apparatus that would be 
reconfigurable by a user to deinterleave a data stream according to the Ramsey type 
II or the Forney protocols, or even using a proprietary scheme. This vAll provide 
users with a deinterleaver that has greater applicability. More specifically, it allows 
a user in the United States to receive and deinterleave interleaved data from Europe 
without having to purchase a deinterleaving apparatus utilizing a different 
algorithm. 

One technique for providing a multipurpose deinterieaver is to include the 
appropriate circuitry for all desired deinterieavers in a single apparatus and then use 
a hardware or software switch to engage the desired deinterieaver. Such a system 
for deinterleaving one of two types of interieaved data is shown in Figure 4 for the 
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RAM based deinterleave implementation approach. In Fig. 4, the R.AJV1 is 400. the 
data is in 403, and the data out is 404. The two different address generation units 
and control are showTi as 401 and 402, The swtch 405 is used to activate the 
desired deinterleaving algorithm. This "brute-force" scheme has the disadvantage 
5 of requiring a completely separate apparatus for each allowable type of interleaved 

data. For software implementation, requiring multiple separate apparatuses requires 
multiple sizes of the program memory. For hardware implementation on an 
integrated circuit, the multiple separate apparatuses require more transistors and 
therefore more silicon area. In the design of integrated circuits, silicon area is a 

10 critical parameter in manufacturing cost and therefore must be minimized wherever 

possible. Furthermore, the high cost of having a separate apparatus for each 
deinterleaving protocol gets worse as more protocols are added to the deinterleaver. 

Figure 5 shows a block diagram of the preferred embodiment of the present 
invention which is used in place of 301 in Fig. 3 or in place of 401, 402, and 405 

15 in Fig. 4. The Generate Write Address block 500 remains the same for all 

interleaving protocols. It generates an address for writes which restarts every time 
the last address is written. The Generate Read Address block 501 remains the 
same for all interieaving protocols. It generates the read address for the RAM. 
The parameters specific to each interleaving algorithm are generated in the 

20 Parameter Set blocks 502, 503, and 504. There can be an arbitrary number of 

these units, one for each interleaving protocol. The commutator 505 switches the 
correct set of parameters into 500 and 501 for each interleaving protocol. When 
this device is used in place of 301 in Fig. 3, it allows apparatus 300 to receive a 
data stream 302 which has been interleaved according to one of a plurality of 

25 interleaving schemes and output the original data stream to 303. The control block 

506 is the same for all interleaved data streams and allows the address generation 
and parameter units to update based on data either being written to the RAM 
through 302 or read from the RAM through 303. Because the blocks 500, 501, and 

« 

506 are reused for all interleaving protocols, cost efficiency is achieved. 
30 Furthermore, this invention places the most complexity in blocks 500, 501, and 506 

and therefore the parameter sets 502, 503, and 504 can be very low cost. 

- 5 - 
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Figure 6 shows one possible hardware implementation of the inveniion of 
Figure 5. This example deinterleaves two possible t>'pes of interleaved data 
streams, the Ramsey t\'pe II interleaved data stream and the Forney interleaved data 
stream. This example is designed to work with a single port RAA-l which requires 
5 reads and wTites to be disjoint in time, hence the mux 605. For this 

implementation a read always precedes a write since the same address can 
generated by both the read address 604 and write address 600 circuitry. Another 
possible hardware implementation for a dual port RAM allows concurrent reads and 
writes and would eliminate the need for the mux 605. 
10 Blocks 605, 606, 607, 608, 609, 610, and all objects labeled 612 are two 

input muxes. These devices route either the '0' input or the '1' input to the 'm' 
output based on the value of the- select signal arriving at the side of the object. All 
blocks labeled 611 are summation devices and the block labeled 613 is a 
subtraction device. All blocks labeled 614 are data storage devices. All blocks 
15 labeled 615 are equalit>' comparators, whose output goes active when the equality 
test is evaluated true. The block 616 is a greater-than-or-equal-to comparator. 

The Write Address Generation Unit 600 increments linearly through the 
RAM address space until it reaches tiie RAM size, selected by tiie mux 606, at 
which time it starts over at the first address. The go_write signal tells tiie write 
address to increment every time a byte is received at tiie RAM and is generated by 
the contirol 506 (Figure 5). 

The Read Address Generation Unit 604 changes tiie read address when tiie 
go_read signal is asserted indicating tiiat data is to be removed from die RAM. 
The go-read signal is generated by tiie control 506 and will not begin to assert until 
25 tiie RAM has been completely written once. After tiiis time, tiie go_read signal 

always asserts when a new byte is received at tiie RAM. In otiier words, once tiie 
RAM has been written once, data is read out of tiie RAM only when data is written 
into tiie RAM. To flush tiie RAM, a dummy byte can be written under control 
506. When tiie read address exceeds flie RAM size, muxed tiu-ough 606, then tiie 
30 RAM size is subtracted from tiie read address. 

The two sets of parameters 601 and 602 are shown in tiie example of Figure 
6. The Ramsey II parameter set 601 provides dynamic information to tiie Read 



20 
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Address Generation Unit 604. The Forney parameter set 602 provides fixed 
information to the Read Address Generation Unit 604. The set of muxes 603 
perform the ftmction of the commutator 505 (Figure 5) and is set before 
deinterleaving occurs. In the set of muxes for this implementation are the RAM 
size, from mux 606; an additional count number of 0 or 1, from mux 607 the 
Ramsey type II nl parameter, from mux 608; a coimt parameter, from mux 609; 
and a mux select signal from mux 610. The select signal to mux group 603 
chooses among the two interleave types. 

The Ramsey type II deinterleave is performed by noticing from Figure 1 
that the original data is ordered by offsets of n2 except every nl+1 it is offset by 
n2+nl+l. The circuit pair 601 and 604 generate the read addresses to extract the 
original ordering out of the interleaved data stream. 

The Forney deinterleave performs by noticing from Figure 2 that Forney 
interleaved data has the origmal data ordered by offsets of N+1. Deinterleaving is 
accomplished by reading in steps of N+1 until N*l is reached at which time the 
read address N*I-(N+1)*I = I is read which is the I^ data of the original stream. 
Then steps of N+1 continue. The circuit pair 602 and 604 generate the read 
addresses to extract the data out of the interleaved data stream. 

The present mvention has been described in terms of specific embodiments 
incorporating details to facilitate the understanding of the principles of construction 
and operation of the invention. Such reference herein to specific embodiments and 
details thereof is not intended to limit the scope of the claims appended hereto. It 
will be apparent to those skilled in the art that modifications may be made in the 
embodiment chosen for illustration without departing from the spirit and scope of 
the invention. Specifically, it will be apparent to one of ordinary skill in the art 
that the apparatus disclosed above is only illustrative of the preferred embodiment 
of the present invention and is in no way a limitation. 



wo 96/37050 PCTAJS96/04758 

CLAIMS 

We claim: 

1. .A deinterleavmg apparatus comprising a data input for receiving a stream of 
data that was interleaved according to one of a plurality of interleaving algorithms, 
and a control input for receiving a signal for selectively configuring the apparatus 
to deinterleave the stream of interleaved data accordmg to a predetermined 

5 deinterleaving algorithm. 

2. The deinterleaving apparatus according to claim 1 ftirther comprising an 
interleaving circuit coupled to the data input for selectively configuring the 
apparatus to interleave a stream of data. 

3. An interleaving/deinterleaving apparatus, comprising: 

a. an input means for receiving an input stream of data bytes; 

b. a random access memory having a plurality of data byte storage 
locations coupled to receive the input stream; 

5 c. a write address generator coupled to the memory for directing each 

byte in the input stream to an appropriate one of the storage 
locations; 

d. a read address generator coupled to the memory for selecting which 
of the locations will provide a data byte to an output stream; - 

e. an output means coupled to the memory for receiving the output 
stream; and 

f. a controller coupled to the memory, the write address generator and 
the read address generator, the controller including a plurality of 
parameter sets, each parameter set for allovyang the controller to 
interleave or deinterieave an input stream according to one of a 
plurality' of interleaving algorithms. 



-8. 
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4. The interleaving/deinterleaving apparatus according to claim 3, wherein the 
\%Tite address generator and controller place an input stream into the memor)% by 
linearly incrementing a storage location address from a first address to a last 
address and wherein the read address generator selects locations acco/ding to a 

5 selected on of the interleaving algorithms. 

5. .The interleaving/deinterleaving apparatus according to claim 3, wherein one 
of the parameter sets directs the controller to execute a Ramsey II interleaving 
algorithm. 

6. The interleaving/deinterleaving apparatus according to claim 3, wherein one 
of the parameter sets directs the controller to execute a Forney interleaving 
algorithm. 



1 7. A de-interleaving apparatus selectively configurable for data streams 

2 interleaved according to one of a plurality of interleaving schemes, the de- 

3 interleaving apparatus comprising: 

4 a. an input means for receiving a data stream interleaved according to 

5 one of a plurality of interleaving schemes; 

6 b. a plurality of de-interleaving means coupled to the input means for 

7 de-interleaving the data stream according to a specific de-interleaving 

8 algorithm; 

9 c. a switch means coupled between the input means and the plurality of 

10 de-interleaving means for allowing a user to selectively route the 

1 1 data stream through a specific de-interleaving means; and 

12 d. an output means coupled to the de-interleaving means for outputting 

13 a de-interleaved data stream representing the original data. 

1 8. The de-interleaving apparatus according to claim 7 wherein each of the 

2 plurality of de-interleaving means further comprises: 

3 a. a read enable means for reading a byte from the data stream 

4 interleaved according to one of a plurality of interleaving schemes; 

-9- 
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^ b. a write enable means coupled to the read enable means for wriiine a 

6 byte of the interleaved data stream; and 

' ^ random access memory coupled to the uxite enable means for 

8 storing a reordered sequence of data corresponding to an original 

9 . data stream. 

1 9. The de-interleaving apparatus according to claim 7 wherein the plurality of 

2 de-interleaving means includes a de-interleaver configured to de-interieave a data 

3 stream interleaved according to a Ramsey II interleaving scheme. 

1 10. The de-interleaving apparatus according to claim 7 wherein the plurality of 

2 de-interleaving means includes a de-interieaver configured to de-interleave a data 

3 stream interleaved according to a Ramsey III interleaving scheme. 

1 1 L A method of de-interleaving a data stream mterleaved according to one of a 

2 plurality of interleaving schemes comprismg the steps of: 

3 . a. inputting a stream of interleaved data; 

4 b. routing the stream of data through a user selected one of a pluralitj^ 
^ of data paths each path corresponding to a different de-interleaving 

6 algorithm; 

7 c. de-interleaving the stream of data within one of the configured data 

8 paths to form an original stream of data; and 

9 d. putputting an original stream of data. 

1 12, The method of de-interieaving a data stream according to claim 1 1 wherein 

2 the step of de-interieaving further comprises the steps of: 

3 a, reading a byte of data from the stream of interleaved data; and 

4 b, writing the byte of data to a specific random access memory location 

5 according to a de-interleaving algorithm corresponding to the user 

6 selected data path. 

- 10- 
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13. The method of de-interleaving a data stream according to claim 1 1 wherein 
the step of routing the stream of data includes routing the stream of data through a 
data path corresponding to a Ramsey II de-interleaving algorithm. 

14. . The method of de-interleaving a data stream according to claim 1 ] wherein 
the step of routing the stream of data includes routing the stream of data through a 
data path corresponding to a Ramsey III de-interleaving algorithm.. 



- 11 - 
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